

**METHOD AND DEVICE FOR EVALUATING PERFORMANCE****Publication number:** JP2000311186**Publication date:** 2000-11-07**Inventor:** HASHIMOTO TAKEHISA; ISHIKAWA HITOSHI**Applicant:** SONY CORP**Classification:**

- international: G06F17/50; G06F17/50; (IPC1-7): G06F17/50

- European:

**Application number:** JP19990122733 19990428**Priority number(s):** JP19990122733 19990428**Report a data error here****Abstract of JP2000311186**

**PROBLEM TO BE SOLVED:** To shorten man-hour for design for performance evaluation and to more shorten time for simulation. **SOLUTION:** A description concerning a performance evaluation model for evaluating the performance of the hardware structure of an LSI is separated to an algorithm part expressing the function of the hardware structure and an architecture part to affect the performance of the hardware structure and the performance of the hardware structure is evaluated on the basis of the description in the algorithm part and the description in the architecture part. Besides, a mode M is set as an interface for relating the separated algorithm part and architecture part.



Data supplied from the esp@cenet database - Worldwide

(19)日本国特許庁 (JP)

(12) 公開特許公報 (A)

(11)特許出願公開番号

特開2000-311186

(P2000-311186A)

(43)公開日 平成12年11月7日 (2000.11.7)

(51)Int.Cl.<sup>7</sup>

G 0 6 F 17/50

識別記号

F I

テ-マコ-ト<sup>\*</sup>(参考)

C 0 6 F 15/60

6 6 4 K 5 B 0 4 6

審査請求 未請求 請求項の数33 O.L (全 15 頁)

(21)出願番号 特願平11-122733

(22)出願日 平成11年4月28日(1999.4.28)

(71)出願人 000002185

ソニー株式会社

東京都品川区北品川6丁目7番35号

(72)発明者 橋本 翔久

東京都品川区北品川6丁目7番35号 ソニ  
ー株式会社内

(72)発明者 石川 仁

東京都品川区東五反田1丁目14番10号 株  
式会社ソニー木原研究所内

(74)代理人 100067736

弁理士 小池 晃 (外2名)

Fターム(参考) 5B046 AA08 BA02 JA04

(54)【発明の名称】 性能評価方法及び装置

(57)【要約】

【課題】 性能評価のための設計工数を短くし、シミュレーションの時間をより短縮可能とする。

【解決手段】 LSIのハードウェア構造の性能を評価するための性能評価モデルに関する記述を、ハードウェア構造の機能を表現しているアルゴリズム部分とハードウェア構造の性能に影響を及ぼすアーキテクチャ部分とに分離し、アルゴリズム部分の記述とアーキテクチャ部分の記述に基づいて、ハードウェア構造の性能を評価する。また、分離されているアルゴリズム部分とアーキテクチャ部分とを関連付けるインターフェイスとしてモードMを設定している。



本発明の性能評価モデルの構造

## 【特許請求の範囲】

【請求項1】 ハードウェア構造を計算機により演算可能な記述としてモデル化し、当該モデル化したハードウェア構造の性能を当該計算機を用いて評価する性能評価方法において、

上記ハードウェア構造の性能を評価するための性能評価モデルに関する記述を、上記ハードウェア構造の機能を表現しているアルゴリズム部分と上記ハードウェア構造の性能に影響を及ぼすアーキテクチャ部分とに分離し、上記アルゴリズム部分の記述とアーキテクチャ部分の記述に基づいて、上記ハードウェア構造の性能を評価することを特徴とする性能評価方法。

【請求項2】 上記分離されているアルゴリズム部分とアーキテクチャ部分とを関連付けるインターフェイスとしてモードを設定することを特徴とする請求項1記載の性能評価方法。

【請求項3】 上記アルゴリズム部分が行う機能的な演算によって上記性能が変化するとき、上記アルゴリズム部分は、上記性能の変化を異なるモードとして計算し、当該モードを上記アーキテクチャ部分に与えることを特徴とする請求項2記載の性能評価方法。

【請求項4】 上記アーキテクチャ部分は、上記ハードウェア構造のうちの性能に影響する部分を、データの入出力が可能なリソースの結合されたものとして保持し、それらリソースの間のデータの入出力を制御することにより、上記性能を求めることが特徴とする請求項2記載の性能評価方法。

【請求項5】 上記リソース間でデータ入出力を行う制御のための記述を、上記リソースの種類に依存しない性質に関する記述と、上記リソースの種類に依存する性質に関する記述とに分離して保持することを特徴とする請求項4記載の性能評価方法。

【請求項6】 上記リソースの種類に依存しない性質に関する記述は、任意のリソースを最小単位のリソースの結合とする旨の記述を含むことを特徴とする請求項5記載の性能評価方法。

【請求項7】 上記リソースの結合とは、单一のリソースから複数のリソースに結合する分岐と、複数のリソースから单一のリソースに結合する集約とを含むことを特徴とする請求項6記載の性能評価方法。

【請求項8】 上記リソースは、上記リソースの結合を上記モードに応じて複数個所持するリソースを含むことを特徴とする請求項6記載の性能評価方法。

【請求項9】 上記リソースの種類に依存しない性質に関する記述は、最小単位のリソース内に同時に2つ以上のデータの存在を許可しない旨の記述を含むことを特徴とする請求項5記載の性能評価方法。

【請求項10】 上記リソースの種類に依存しない性質に関する記述は、任意のリソースはデータが出力可能であり、且つ上記リソースの結合により結合された先のリ

ソースがデータを入力可能であるならば、データを必ず移動する旨の記述を含むことを特徴とする請求項6記載の性能評価方法。

【請求項11】 上記リソースの種類に依存する性質に関する記述は、上記リソースのデータ入力が可能かどうかの判断において、データを保持しているか否か、及び上記リソースの結合において後方に結合されたリソースがデータ入力可能か否か、のいずれの情報を利用するかを表す記述を含むことを特徴とする請求項6記載の性能評価方法。

【請求項12】 上記リソースの種類に依存する性質に関する記述は、上記リソースの結合が上記分岐である時に、どのような情報を利用するかを表す記述を含むことを特徴とする請求項7記載の性能評価方法。

【請求項13】 上記リソースの種類に依存する性質に関する記述は、上記リソースの結合が上記集約である時に、どのような情報を利用するかを表す記述を含むことを特徴とする請求項7記載の性能評価方法。

【請求項14】 上記リソースの種類に依存しない性質及び上記リソースの種類に依存する性質に関する記述をライブラリ情報として提供し、

当該ライブラリ情報の組み合わせによってリソースを定義し、  
それらリソースの結合を記述することにより、上記性能を評価することを特徴とする請求項5記載の性能評価方法。

【請求項15】 上記アルゴリズム部分と上記アーキテクチャ部分の間で、複数個のモードを保持することを特徴とする請求項2記載の性能評価方法。

【請求項16】 上記リソースにデータが入力されるとき、上記リソースが保持する上記モードに対応したリソースの結合の先頭リソースに対してデータを入力することを特徴とする請求項8記載の性能評価方法。

【請求項17】 上記リソースが保持する複数のリソースの結合において、出力側に仮想的に1つのリソースを設けることを特徴とする請求項8記載の性能評価方法。

【請求項18】 ハードウェア構造を計算機により演算可能な記述としてモデル化し、当該モデル化したハードウェア構造の性能を評価する性能評価装置において、上記ハードウェア構造の性能を評価するための性能評価モデルに関する記述を、上記ハードウェア構造の機能を表現しているアルゴリズム部分と上記ハードウェア構造の性能に影響を及ぼすアーキテクチャ部分とに分離した記述を保持する保持手段と、

上記保持手段に保持したアルゴリズム部分の記述に基づいて演算を行うアルゴリズム演算手段と、

上記保持手段に保持したアーキテクチャ部分の記述に基づいて演算を行うアーキテクチャ演算部とを有し、  
上記アルゴリズム演算手段とアーキテクチャ演算手段の演算により、上記ハードウェア構造の性能を評価するこ

とを特徴とする性能評価装置。

【請求項19】 上記アルゴリズム演算手段は、入力されたデータに対する演算結果にしたがって、上記分離されているアルゴリズム部分とアーキテクチャ部分とを関連付けるインターフェイスとしてのモードを計算するモード計算手段を有することを特徴とする請求項18記載の性能評価装置。

【請求項20】 上記モード計算手段は、上記アルゴリズム部分が行う機能的な演算によって上記性能が変化するとき、上記アルゴリズム部分の記述に基づいて上記性能の変化を異なるモードとして計算し、当該モードを上記アーキテクチャ演算手段に送出することを特徴とする請求項19記載の性能評価装置。

【請求項21】 上記アーキテクチャ演算手段は、上記ハードウェア構造のうちの性能に影響する部分を、データの入出力が可能なリソースの結合されたものとして保持するリソース保持手段と、それらリソースの間のデータの入出力を制御するデータ制御手段とを有することを特徴とする請求項19記載の性能評価装置。

【請求項22】 上記保持手段には、上記リソース間でデータ入出力を行うための記述を、上記リソースの種類に依存しない性質に関する記述と、リソースの種類に依存する性質に関する記述とに分離して保持することを特徴とする請求項21記載の性能評価装置。

【請求項23】 上記リソースの種類に依存しない性質に関する記述は、任意のリソースを最小単位のリソースの結合とする旨の記述を含むことを特徴とする請求項22記載の性能評価装置。

【請求項24】 上記リソースの結合とは、单一のリソースから複数のリソースに結合する分岐と、複数のリソースから单一のリソースに結合する集約とを含むことを特徴とする請求項23記載の性能評価装置。

【請求項25】 上記リソースは、上記リソースの結合を上記モードに応じて複数個所持するリソースを含むことを特徴とする請求項23記載の性能評価装置。

【請求項26】 上記リソースの種類に依存しない性質に関する記述は、最小単位のリソース内に同時に2つ以上のデータの存在を許可しない旨の記述を含むことを特徴とする請求項22記載の性能評価装置。

【請求項27】 上記リソースの種類に依存しない性質に関する記述は、任意のリソースはデータが output 可能であり、且つ上記リソースの結合により結合された先のリソースがデータを input 可能であるならば、データを必ず移動する旨の記述を含むことを特徴とする請求項23記載の性能評価装置。

【請求項28】 上記リソースの種類に依存する性質に関する記述は、上記リソースのデータ入力が可能かどうかの判断において、データを保持しているか否か、及び上記リソースの結合において後方に結合されたリソースがデータ入力可能か否か、のいずれの情報を利用するか

を表す記述を含むことを特徴とする請求項23記載の性能評価装置。

【請求項29】 上記リソースの種類に依存する性質に関する記述は、上記リソースの結合が上記分岐である時に、どのような情報を利用するかを表す記述を含むことを特徴とする請求項24記載の性能評価装置。

【請求項30】 上記リソースの種類に依存する性質に関する記述は、上記リソースの結合が上記集約である時に、どのような情報を利用するかを表す記述を含むことを特徴とする請求項24記載の性能評価装置。

【請求項31】 上記アルゴリズム部分と上記アーキテクチャ部分の間で、複数個のモードを保持するモード保持手段を有することを特徴とする請求項19記載の性能評価装置。

【請求項32】 上記データ制御手段は、上記リソースにデータが入力されるとき、上記リソースが保持する上記モードに対応したリソースの結合の先頭リソースに対してデータを入力することを特徴とする請求項25記載の性能評価装置。

【請求項33】 上記データ制御手段は、リソースが保持する複数のリソースの結合において、出力側に仮想的に1つのリソースを設けることを特徴とする請求項25記載の性能評価装置。

#### 【発明の詳細な説明】

##### 【0001】

【発明の属する技術分野】 本発明は、大規模集積回路（LSI）のアーキテクチャ設計の性能評価方法及び装置に関する。

##### 【0002】

【従来の技術】 LSI 設計者が LSI を設計する場合の従来の設計フローを図20に示す。

【0003】 従来の設計フローでは、最初に、ステップ S101 として、要求仕様に基づいて機能の設計を行い、次に、ステップ S102 として、評価のために、シミュレータとしての機能評価モデルを作成し、その後、ステップ S103 として、機能評価モデルが要求仕様を満たすかどうかを確認する。当該ステップ S103 において、もし機能評価モデルが要求仕様を満たさなければ（NO）、ステップ S101 に戻って再度機能を見直す。

【0004】 ステップ S103 において、機能評価モデルが要求仕様を満たしていることが確認できた（YE S）後は、ステップ S104 として、機能の実現方法としてのアーキテクチャの設計を行う。ここで、アーキテクチャによって性能が左右されるので、ステップ S105 として、実行時間をシミュレートするための性能評価モデルを作成して、次に、ステップ S106 として、要求仕様を満たすかどうか確認する。このステップ S106 において、要求仕様を満たさない（NO）ものであれば、ステップ S104 に戻ってアーキテクチャの再設計

を行い、要求仕様を満たした（YES）ならば設計が完了する。

【0005】ここで、機能評価モデルは、機能を数学的に表現したアルゴリズムと、アルゴリズムで処理するデータの入力又はその処理結果データの出力の何れか、或いはそれらの両方を持つ。なお、このレベルではハードウェアの処理にかかる時間は意識しない。機能評価モデルを作成する場合は、アルゴリズムをC言語として知られるような適切な高レベル言語で記述する。機能評価モデルは、要求仕様の中の機能が実現されたモデルであり、設計対象の論理的な振る舞いを表現しているという意味でビヘイビアモデルとも呼ばれる。

【0006】一方、性能評価モデルでは、機能評価モデルで記述したアルゴリズムについて、実際のハードウェアでの処理にかかる時間を記述し、シミュレーションする。ただし、時間の記述には、2つのレベルが存在する。

【0007】一つは、ハードウェアの1クロックを最小単位とし、回路を構成する論理ゲートや配線による遅延を考慮しない時間的な概念であり、一般にレジスタ転送レベル（RTL）と呼ばれる。このような時間概念を、以下、レベル1の時間概念と呼ぶことにする。

【0008】またもう一つは、ハードウェアのクロックの単位よりも詳細に、回路を構成する論理ゲートや配線による遅延も考慮に入れた時間的な概念である。このような時間概念を、以下、レベル2の時間概念と呼ぶことにする。

【0009】このような時間概念の考慮された性能評価モデルのシミュレーションを行う公知の技術では、ハードウェア記述言語（HDL）によって記述されたモデルを検証するHDLシミュレータがある。HDLシミュレータには、レベル1の時間概念に基づいてタイミングと機能を検証するサイクルベースシミュレータと、レベル2の時間概念に基づいて厳密な処理のタイミングと機能を検証するイベントドリブンシミュレータが存在する。

【0010】また、別の性能評価モデルを作成して評価するための既存の技術として、レジスタ転送C（RTC）言語による記述がある。これは既存のC言語にハードウェアのクロックの概念を持ち込み、1クロック毎の処理をC言語で記述することにより、レベル1の時間概念に基づいてタイミングと機能の検証を可能とするものである。

【0011】ここで、レベル1の時間概念における、HDLによる性能評価モデルとRTCによる性能評価モデルを比較してみる。

【0012】HDLによる性能評価モデルによるシミュレーション実行の前提条件としてHDL言語による記述が必要である。HDL言語による記述は、ハードウェアクロックを意識した並行的な動作の記述という点にお

いてC言語の記述とは異なる。したがって、機能評価モデルとして作成したものとは別途作成する必要がある。そのため、機能評価が完了した後に性能評価モデルを作成して性能評価を行うまでに設計工数が大きくかかるという問題がある。

【0013】それに対して、RTCを利用する場合は、機能評価モデルをC言語で作成してあれば、それを流用して性能評価モデルを作成することが可能である。したがって、HDLシミュレータと比較して、性能評価を行うまでの設計工数が短くなる。

【0014】また、HDLシミュレータは、前述通り、ハードウェアを意識した詳細なレベルのシミュレーションを行うため、性能評価としての精度は良くなるが、レベル1での時間概念のレベルで必要となる抽象的な記述には向いていないため、モデルの抽象度が下がり、シミュレーションそのものにかかる時間も非常に長くなるという問題がある。それに対してRTCを利用する場合は、C言語のレベルで動作するので、同等な時間概念のレベルであるHDLのシミュレータよりもシミュレーションそのものの実行時間を短縮することができる。

【0015】以上のことから、レベル1の時間概念のレベルでの性能評価には、HDLよりもRTCを利用した性能評価モデルを用いた方が、性能評価を行うまでの設計工数及び性能評価のためのシミュレーション時間は短縮されることになる。

#### 【0016】

【発明が解決しようとする課題】しかし、RTCを用いた性能評価モデルにおいても、性能評価のための設計工数や、シミュレーション実行時間の短縮は未だ不十分である。

【0017】すなわち機能評価モデルは、アルゴリズムの記述である演算のみの組み合わせから記述を行う。これは、ハードウェア構造に無関係である。したがって、RTCを用いた性能評価モデルであっても、ハードウェアを意識した記述を行うならば、たとえ利用する言語が同じであっても、再度書き直す必要が生じる。

【0018】このことが、性能評価のための設計工数に大きく影響を与える。また、この場合の記述では、記述するレベルがハードウェアに非常に近く、C言語を使用していながら、抽象的な記述を行うことが少ない。

【0019】そこで、本発明はこのような状況に鑑みてなされたものであり、性能評価のための設計工数を短くでき、また、シミュレーションの時間をより短縮することが可能な、性能評価方法及び装置を提供すること目的とする。

#### 【0020】

【課題を解決するための手段】本発明の性能評価方法は、ハードウェア構造を計算機により演算可能な記述としてモデル化し、当該モデル化したハードウェア構造の

性能を当該計算機を用いて評価する性能評価方法であり、上記ハードウェア構造の性能を評価するための性能評価モデルに関する記述を、上記ハードウェア構造の機能を表現しているアルゴリズム部分と上記ハードウェア構造の性能に影響を及ぼすアーキテクチャ部分とに分離し、上記アルゴリズム部分の記述とアーキテクチャ部分の記述に基づいて、上記ハードウェア構造の性能を評価することにより、上述した課題を解決する。

【0021】また、本発明の性能評価装置は、ハードウェア構造を計算機により演算可能な記述としてモデル化し、当該モデル化したハードウェア構造の性能を評価する性能評価装置であり、上記ハードウェア構造の性能を評価するための性能評価モデルに関する記述を、上記ハードウェア構造の機能を表現しているアルゴリズム部分と上記ハードウェア構造の性能に影響を及ぼすアーキテクチャ部分とに分離した記述を保持する保持手段と、上記保持手段に保持したアルゴリズム部分の記述に基づいて演算を行うアルゴリズム演算手段と、上記保持手段に保持したアーキテクチャ部分の記述に基づいて演算を行うアーキテクチャ演算部とを有し、上記アルゴリズム演算手段とアーキテクチャ演算手段の演算により、上記ハードウェア構造の性能を評価することにより、上述した課題を解決する。

【0022】すなわち、本発明の性能評価方法及び装置は、LSI（大規模集積回路）アーキテクチャ設計の性能評価において、構造と機能を切り離してモードという単純なインターフェイスで関係を表現し、またアーキテクチャの記述を抽象化することにより、性能評価モデルを作成する場合に、最初から作成し直すのではなく、機能評価モデルをそのまま利用できるようにして性能評価のための設計工数を短くすることを可能とし、また、性能評価モデルの記述をより抽象的なレベルで行うようにしてシミュレーションの時間をより短縮することを可能としている。

### 【0023】

**【発明の実施の形態】**本発明の好ましい実施の形態について、図面を参照しながら説明する。

【0024】本発明の性能評価方法及び装置の具体的な実施の形態の説明に先立ち、例えば性能評価のための設計工数を短くし、また、シミュレーションの時間をより短縮するために本発明が採用している2つの方法と、本発明との比較のための一般的な性能評価モデルの構造と、本発明に係る性能評価モデルとについて、以下に説明する。

【0025】本発明が採用している第1、第2の2つの方法のうち、第1の方法では、性能と機能を切り離して記述し、モードという抽象的なインターフェイスを定義してこの2つの関係を表現する。

【0026】また、第2の方法では、上述の性能評価モデルにおけるアーキテクチャの記述を、リソーススケジ

ューリングという考え方を用いて容易にし、シミュレーション実行環境を簡単に実現できるようにしている。

【0027】ここで、上記第1の方法では、性能評価モデルの記述の中で、機能を表現しているアルゴリズム部分と、変化することで性能に影響を及ぼすアーキテクチャ部分とを切り離して記述する。また、この切り離しを実現するために、モードという抽象的なインターフェイスを定義して、アーキテクチャとアルゴリズムの関連を表現する。なお、以下では、このような時間的な概念を表すモデルをアーキテクチャと呼ぶようとする。

【0028】図1には、本発明との比較のための一般的な性能評価モデルの構造を示す。なおここでは、設計対象のアーキテクチャの構成要素、つまりアーキテクチャの一部分を、ブロックと定義する。

【0029】この図1において、あるデータが、ブロックBAを通過して、次に到達するブロックがブロックBBであるかブロックBCであるかは、ブロックBAでのデータの演算Caの結果に依存する場合がある。ブロックBA、BB、BCでかかる処理時間がそれぞれTA、TB、TCであるとし、また、それらの処理時間TA、TB、TCはそれぞれ常に一定であると仮定した場合、データに依存してこの系全体の処理にかかる時間は、

(TA+TB)である場合と(TA+TC)である場合とがあり得る。この場合、データがブロックを通過する経路が機能に依存しており、そのためデータの系全体の処理時間が機能に依存している。

【0030】しかし、機能設計を行う際には、このようなアーキテクチャの構成を意識して行わないため、このようなモデルで性能評価を行うのならば、機能評価を行う時に作成した機能評価モデルは性能評価には全く利用できず、性能評価に当たっては性能評価モデルを最初から設計し直すこととなる。更に、機能自体は変化しないが、アーキテクチャ構造が変化した場合、一度作成した性能評価モデルを、構造が変化した部分に関して、機能も含めて作成し直す必要が生じる。しかし、機能には変化がないので本来であれば機能は作成し直す必要はないはずである。

【0031】これに対して、図2で示される本発明の性能評価モデルでは、アルゴリズムとアーキテクチャが切り離されている。

【0032】ここで、あるデータが演算Caの処理を終了し、その結果次に演算Cbが必要である、という場合をモードM1と定義する。また、あるデータが演算Caの処理を終了し、その結果次に演算Ccが必要である、という場合をモードM2と定義する。

【0033】アーキテクチャ部では、モードM1の場合、データはブロックBAを通過してその次にブロックBBを通過する、というモデルを持っており、また、モードM2の場合、データはブロックBAを通過してその次にブロックBCを通過する、というモデルを持ってい

る。このモデルを利用することにより、アーキテクチャ部を、変化しないアルゴリズム部と切り離して、性能評価モデルの作成を行うことができる。したがって、性能評価のための設計工数を短縮することができるようになる。

【0034】のことにより、機能評価モデル決定後に例えばアーキテクチャ構造が変化した場合でも、一度作成した性能評価モデルは、機能に変化がなくアーキテクチャ部分とアルゴリズム部分のインターフェイスが変わらないならば、アーキテクチャ部分だけの変更で性能評価を行うことが可能となる。

【0035】一方、ハードウェアアーキテクチャ構造は、パイプライン構造などの公知のアーキテクチャの例のように、機能によって変化しない。したがって、機能部分とアーキテクチャ部分の切り離された性能評価モデルを利用すれば、アーキテクチャの部品化を促進することができる。さらに、このアーキテクチャ構造の部品は機能を持たないため、上記「モード」のような部品のインターフェイスの統一が容易であり、そのため性能評価モデル作成の上でアーキテクチャ部品の再利用化が促進されることが期待される。

【0036】次に、第2の方法では、上述の性能評価モデルにおけるハードウェアアーキテクチャの記述を、リソーススケジューリングという考え方を用いて容易にし、シミュレーション実行環境を簡単に実現できるようになっている。この結果、性能評価のための設計工数を短縮することが可能となる。

【0037】また、アーキテクチャの記述をリソーススケジューリングという考え方を用いて抽象化したレベルで行うことで、シミュレーション実行時間を短縮することが可能となる。

【0038】以下、リソーススケジューリングについての説明のために、トークンとリソースについて定義し、更にリソーススケジューリングについて定義する。

【0039】トークンとは、ハードウェア内部で処理されるデータの任意の単位であると定義する。また、リソースとは、トークンを同一時間に限られた数のみ保持できる、ハードウェアアーキテクチャの構成要素であると定義する。さらに、リソーススケジューリングとは、設計者が決めることができない、種類に依存しない全てのリソースが持つ以下の3点の法則（UA1, UA2, UA3）にしたがって、リソースをスケジューリングすることである。なお、以下、法則のことをUA（Universal Architecture）と呼ぶことにする。

【0040】UA1では、最小単位のリソースの中にはトークンが同時に2つ以上存在することができない。

【0041】UA2では、あるリソース中に存在するトークンはこのリソースから外に出ることが可能であり、次に移動する先のリソースが受付可能であるのならば必ず移動する。

【0042】UA3では、どのようなリソースも、最小単位のリソースの組み合わせによって構成される。

【0043】ここで、リソース間をトークンが移動するかどうか（以下ではこのことを遷移条件と呼ぶ）は、リソースの種類に応じて変化する。遷移条件はリソースの種類によって異なるポリシーの組み合わせによって決定される。UAに加えて、リソースのポリシーが与えられることによって、リソースの種類（型）が決定する。

【0044】以下、リソースのポリシーをSA（Specific Architecture）と呼ぶことにする。

【0045】実際のリソースは、上記リソースの種類に加えて、リソース内部の構造を定義したものになる。なお、リソースは階層的に定義可能であり、内部構造を持つリソースとは、内部にリソースを持つリソースのことである。内部にリソースを持たない最小単位のリソースには、内部構造はない。

【0046】図3には、本発明におけるリソースの抽象化モデルの概要を示す。

【0047】この図3において、「リソース」は、「リソースの種類の定義」及び「構造の定義」からなる。

「リソースの種類の定義」は、どのリソースにも共通な「リソーススケジューリングの法則（UA）」と、種類によつて異なる「リソースのポリシー（SA）」からなる。

【0048】リソースの「構造の定義」は、当該リソースが下位のどのようなリソースの組み合わせから構成されているかを示している。

【0049】以下、リソースの構造について説明する。

【0050】図4には、リソースの構造、つまりリソースの階層構造の例を示す。

【0051】この図4において、リソースAは、それよりも下位のリソースa、リソースb、リソースcの結合からなっている。なお、この図中の矢印は、トークンが遷移する方向を示している。

【0052】図5には、モードM1, M2とリソースAの結合との関係を示す。

【0053】この図5において、同一リソースAであっても、モードM1のときは、それよりも下位のリソースa、リソースb、リソースbの順にトークンが遷移するように結合されているが、モードM2のときは、下位のリソースa、リソースbの順にトークンが遷移するように結合されていると考える。つまり、リソースは、このような内部の構造をもっている。なお、上記モードM1の場合は、トークンが下位のリソースbを二回繰り返して通過するように結合されている。

【0054】また、リソースの結合は一対一の結合とは限らない。すなわち、図6に示すように、リソースaから、リソースb, c, dに「分散」してトークンが遷移するような結合も考えられ、また、リソースe, d, fからリソースhに「集約」してトークンが遷移するよう

な結合も考えられる。

【0055】本発明では、これらの定義を用いて、多くのハードウェアアーキテクチャが容易に記述できることを利用している。実際には、個々のハードウェアアーキテクチャは個々の特徴を持つが、以下に示すような限られた選択肢から選ぶことができる。

【0056】ここで、あるリソースRがトークンを受け付けるポリシーを「SA1」とし、また、時刻tにリソースRにトークンが入ってきている状態が有りうることを、「時刻tにリソースRはトークンを受付可能である」と定義する。

【0057】このとき、あるリソースRがトークンを受け付けるポリシーとしては、例えば以下の3種類のポリシー(SA1-1、SA1-2、SA1-3)を考えられ、これらのうちの何れかが選択される。

【0058】SA1-1では、あるリソースRが時刻tにおいてまさに空いているならば、時刻(t+1)にトークンを受け付けることが可能である。

【0059】SA1-2では、あるリソースRの次にトークンが移動するであろうリソースR'が時刻(t+1)において受付可能であるとき、リソースRは時刻(t+1)に受付可能になる。

【0060】SA1-3では、時刻tにおいてあるリソースRがまさに空いているか、又は次にトークンが移動するであろうリソースR'が時刻(t+1)において受付可能であるとき、リソースRは時刻(t+1)に受付可能である。なお、SA1-3とは、(SA1-1)+(SA1-2)のポリシーである。

【0061】また、トークンが分岐する場合、すなわちあるリソースRに存在するトークンがリソースRから外に出ることが可能で、複数のリソースR1、R2、…、Rnに同時に遷移する場合のポリシーを「SA2」とする。このときのポリシーとしては、例えば以下のSA2-1が考えられる。

【0062】SA2-1では、リソースRに存在するトークンが外に出ることが可能であり、リソースR1、R2、…、Rnが全て同時に受付可能である場合、トークンはリソースRからリソースR1、R2、…、Rnに分岐して遷移する。このとき、リソースR1、R2、…、Rnのそれぞれが受け付けることが可能であるかどうかは、SA1のいずれかのポリシー(SA1-1、SA1-2、SA1-3)に基づいて決定される。

【0063】さらに、トークンが集約する場合、すなわち複数の入力元リソースR1、R2、…、Rnからトークンが1つのリソースRに遷移する場合のポリシーを「SA3」とする。このときのポリシーとしては、以下のSA3-1が考えられる。

【0064】SA3-1では、複数のリソースR1、R2、…、Rnの全てにトークンが存在して、全ての

トークンが外に出ることが可能であるのならば、トークンはリソースR1、R2、…、RnからリソースRに集約して遷移する。このとき、リソースRが受付可能であるかどうかは、SA1のいずれかのポリシー(SA1-1、SA1-2、SA1-3)に基づいて決定される。

【0065】なお、本発明での具体的なポリシーの定義は、SA1については3種類(SA1-1、SA1-2、SA1-3)、SA2については1種類(SA2-1)、SA3については1種類(SA3-1)のみに止まっているが、これらは拡張可能であり、他のポリシーに基づいてモデル化することも考えられる。

【0066】このようにして、UA(法則)と、個別のSA(ポリシー)を予めライブラリとして提供することにより、ユーザすなわち性能評価者は、これらの組み合わせ及び構造を利用することによって簡単に性能評価モデルを作成することができ、性能評価のための設計工数を短縮することができる。

【0067】図7には、本発明に係る性能評価モデルを作成・検証する一実施の形態の性能評価シミュレーション装置の概略構成例を示す。

【0068】この図7の性能評価シミュレーション装置では、先ず、機能の設計の段階で作成した機能評価モデル6を、ユーザが拡張することによりモード計算部1を作成する。機能評価モデル6は、データの入力に対して演算結果を出力するが、モード計算部1は、演算結果ではなく、その演算結果に従ったモードを出力する。出したモードは一時的にモードバッファ2に保存され、適切なタイミングで性能評価モデル部3に取り出され、利用される。

【0069】性能評価モデル部3は、前述のようなリソースの抽象化に基いたモデルを持っていて、入力されたトークンを、適切な処理時間の後に出力する機能を果たしている。なお、本実施の形態の性能評価シミュレーション装置は、トークンの外部との制御のために入力可信号の出力や出力可信号の入力をを持っている。入力可信号は、性能評価モデル部3が外部入出力管理部4からトークンを受付可能かどうかを制御する信号であり、出力可信号は、図示しない外部ブロックが性能評価モデル部3からトークンを受付可能かどうかを制御する信号である。性能評価モデル部3は、初期化時に、設計者の設計したアーキテクチャ構造について、前述のリソースの抽象化に基づいたモデルを実体化する。

【0070】また、本実施の形態の性能評価シミュレーション装置は、モード計算部1や性能評価モデル部3と外部との入出力の間のインターフェイスとして、外部入出力管理部4を有している。

【0071】さらに、本実施の形態の性能評価シミュレーション装置は、性能評価モデル部3や外部入出力管理部4に対して、ハードウェアクロックのタイミングを擬

似的に生成して、動作時間の単位を与えているクロック生成器5をも有している。

【0072】以下、この図7に示した本実施の形態の性能評価シミュレーション装置の各部分の動作について説明する。

【0073】先ず、モード計算部1の動作を説明する。図8には、モード計算部1の動作フローを示す。

【0074】当該モード計算部1では、ステップS1にてデータが入力されると、ステップS2としてモードを計算し、さらにステップS3として当該計算されたモードをモードバッファ2に出力する。当該モード計算部1は、データが入力される毎にすぐに呼び出され、この図8で示されるフローの処理が行われる。

【0075】次に、外部入出力管理部4の動作を説明する。図9及び図10には、当該外部入出力管理部4の動作フローを示す。

【0076】外部入出力管理部4では、クロック生成器5の生成する1クロック毎に処理を行う。先ず、外部入出力管理部4では、ステップS11として、外部からの入カトーケンがあるか否かの判断を行う。外部入出力管理部4は、このステップS11の判断において、外部からの入カトーケンがあると判断した場合(YES)にはステップS12の処理に進み、当該ステップS12にてデータをモード計算部1に渡した後、ステップS13の処理に進む。一方、ステップS11にて外部からの入カトーケンが無いと判断した場合(NO)、外部入出力管理部4の処理はステップS13に進む。

【0077】外部入出力管理部4は、ステップS13の処理に進むと、モードバッファ2の内容を参照し、当該モードバッファ2にモード情報が存在し、且つ性能評価モデル部3からの入カトーケンが入力可であるか否かの判断を行う。外部入出力管理部4は、当該ステップS13の判断において、モードバッファ2にモード情報が存在し、且つ性能評価モデル部3からの入カトーケンが入力可であると判断した場合(YES)にはステップS14の処理に進み、当該ステップS14にて性能評価モデル部3に対して、外部から入力されていたトーケンを渡す。一方、ステップS13にてモードバッファ2にモード情報が存在しないか、或いは、性能評価モデル部3からの入カトーケンが入力可で無いと判断した場合(NO)、外部入出力管理部4の処理は、ステップS15に進む。

【0078】外部入出力管理部4は、ステップS15の処理に進むと、性能評価モデル部3からトーケンが出ており、且つ外部へ出力可能であるか否かの判断を行う。外部入出力管理部4は、当該ステップS15の判断において、性能評価モデル部3からトーケンが出ており、且つ外部へ出力可能であると判断した場合(YES)にはステップS16の処理に進み、当該ステップS16にてそのトーケンを外部に出力し、その後、図10のステップS17の処理に進む。一方、ステップS15

にて性能評価モデル部3からトーケンが出力されないか、或いは、外部へ出力できないと判断した場合(NO)、当該外部入出力管理部4の処理は、図10のステップS17の処理に進む。

【0079】外部入出力管理部4は、ステップS17の処理に進むと、モードバッファ2を参照し、次クロックでモードバッファ2の内容が存在するか否かの判断を行う。外部入出力管理部4は、当該ステップS17の判断において、次クロックでモードバッファ2の内容が存在すると判断した場合(YES)にはステップS18の処理に進み、当該ステップS18にて外部からの入カトーケンを入力不可とする。一方、ステップS17にて次クロックでモードバッファ2の内容が存在しないと判断した場合(NO)、外部入出力管理部4では、ステップS19として、外部からの入カトーケンを入力可とする。なお、外部入出力管理部4では、ステップS17において、モードバッファ2の中にモード情報が存在しないか、あるいはモードバッファ2の中にモード情報が1つ存在し且つステップS14の処理を行ったか、のいずれかの場合に、次クロックでモードバッファ2の内容は存在しないと判断する。ステップS18、ステップS19の処理後、外部入出力管理部4の処理はステップS20に進む。

【0080】ステップS20の処理に進むと、外部入出力管理部4は、外部から与えられた出力可信号を性能評価モデル部3への出力可信号に反映する。

【0081】次に、性能評価モデル部3の動作を説明する。図11には、性能評価モデル部3の動作フローを示す。

【0082】当該性能評価モデル部3でも、上記外部入出力管理部4と同様にクロック生成器5の生成する1クロック毎に処理を行う。

【0083】性能評価モデル部3では、ステップS21として、外部入出力管理部4からの入カトーケンが有ったか否かの判断を行う。性能評価モデル部3は、ステップS21の判断において、外部入出力管理部4からの入カトーケンが有ったと判断した場合(YES)にステップS22の処理に進み、当該ステップS22にてモード計算部1によって計算されたモードをモードバッファ2から取り出し、さらにステップS23にて外部からの入カトーケンをリソースに後述するトーケン入力動作を行う。このステップS23の処理後、性能評価モデル部3の処理はステップS24に進む。一方、ステップS21の判断において、外部入出力管理部4からの入カトーケンが無いと判断した場合、性能評価モデル部3はステップS24の処理に進む。

【0084】ステップS24の処理に進むと、性能評価モデル部3では、展開された全ての最小リソース間について、存在する全てのトーケンの移動を行う。次いで、性能評価モデル部3では、ステップS25として、外部

への出力端となるリソースについて、外部入出力管理部4との間のトークン出力動作を行う。なお、「展開された最小リソース」の意味については後述する。

【0085】ここで、図12には性能評価モデル部3の構成例を示す。図11のステップS23, S24, S25の処理は、当該図12に示す構成により行われる。

【0086】この図12において、性能評価モデル部3は、構造定義部11と、複数のリソース12と、それらリソース12を保持するリソース保持部13、UA保持部14、SA保持部15及びリソース内のトークンの動作を制御するトークン制御部16からなっている。

【0087】構造定義部11には、ユーザであるところのLSI設計者によって設計対象のアーキテクチャ構造が記述される。この記述はアーキテクチャ構造を構成する各リソースの種類と、それらのリソース間の階層構造が記述されている。ただし、この階層構造は、モードに依存して変化するものであり、そのためにモード毎に別々の階層構造が記述されている。図13には、ユーザの記述する構造定義部11の記述例を示す。

【0088】また、性能評価モデル部3は、初期化処理時に、構造定義部11の記述に基づいて、最小リソース保持部13内にリソースのモデルを実体化する。この際には、前記UA3すなわち「どのようなリソースも、最小単位のリソースの組み合わせによって構成される」ことに基づいて、構造定義部11で記述されたリソースの階層構造を最小単位のリソースに展開した形でモデルを実体化する。最小単位のリソースの中には、トークンは同時に2つ以上存在することができない（前記UA1）ことから、最小単位のリソースに展開した形でモデルを実体化することにより、トークン制御部16によるトークンの制御を単純な形にしている。図14には、最小単位のリソースへの展開の概念図を示す。すなわち、性能評価モデル部3は、リソースa, b, cからなるリソースAとリソースj, kからなるリソースBを最小単位のリソースa, b, c, j, kに展開する。

【0089】トークン制御部16は、外部より入力されるトークン、モード、出力可信号にしたがって、UA保持部14とSA保持部15にそれぞれ保持されたUA, SAに基づいて、最小リソース保持部13に保持されたリソースのモデル中に存在するトークンの制御を行っている。つまり、性能評価モデル部3の動作フローである前記図11に示された一連の処理は、トークン制御部16が主体となって処理している。

【0090】以下、図12に示した構成の性能評価モデル部3を参照しながら、図11で示されたステップS23, S24, S25の説明を行う。なお、以下の説明では、簡単のために、トークン制御部16の処理の基本となるステップS24について最初に説明し、その後ステップS23, S25についてそれぞれ説明することにする。

【0091】図15には、リソース間のトークン移動の基本動作を示す。すなわち性能評価モデル部3の動作フローである前記図11のステップS24である、全ての最小リソース間のトークン移動動作は、図15で示されたリソース間のトークン移動の基本動作を、全ての結合された最小リソース間に渡って実行することにより実現される。

【0092】先ず、トークン制御部16では、ステップS31及びS32の処理として、結合された任意の2つの最小リソースR1, R2について、リソースR1の出力条件を判断する。ここで、トークン制御部16は、ステップS31及びS32の判断処理において、リソースR1の出力条件が満たされたと判断した場合（ステップS32がYES）、ステップS33の処理に進む。一方、リソースR1の出力条件が満たされないと判断した場合（ステップS32がNO）、リソース制御部16の処理は終了する。

【0093】トークン制御部16は、ステップS33の処理に進むと、ステップS31及びS33の処理として、結合された任意の2つの最小リソースR1, R2について、リソースR2の入力条件を判断する。ここで、トークン制御部16は、ステップS33の判断処理において、リソースR2の出力条件が満たされたと判断した場合（YES）、ステップS34としてトークンをリソースR1からR2に移動する。一方、ステップS33の判断において、リソースR2の出力条件が満たされないと判断した場合（NO）、リソース制御部16の処理は終了する。

【0094】以下、上述のように2つのリソース間の、1つのトークンの移動に着目した場合、リソースR1をソースリソース、リソースR2をデスティネーションリソースと呼ぶことにする。

【0095】更に、図16には、図15のステップS32における出力条件判断動作の詳細を示す。

【0096】この図16において、トークン制御部16は、ステップS41としてソースリソース中にトークンが1つ存在しているかどうかを判断する。

【0097】このステップS41の判断において、ソースリソース中にトークンが1つ存在していないと判断した場合（NO）、トークン制御部16は、ステップS44として、前記UA2により、このソースリソースはトークンを出力することができないとする。一方、ステップS41の判断において、ソースリソース中にトークンが1つ存在していると判断した場合（YES）、トークン制御部16は、さらにステップS42として、出力先のリソースはデスティネーションリソース以外にも存在するか否か、つまり出力先のリソースは複数かどうかを判断する。

【0098】このステップS42の判断により、出力先のリソースは複数でないと判断した場合（NO）、ト

クン制御部16は、ステップS45として、トークンを出力可とする。また、ステップS42の判断において、出力先のリソースは複数であると判断した場合(YES)、トークン制御部16は、更にステップS43として、ソースリソースの前記SA2(分岐)の条件が満たされるかどうかを判断する。

【0099】このステップS43の判断において、ソースリソースのSA2(分岐)の条件が満たされないと判断した場合(NO)、トークン制御部16は、ステップS44の処理に進み、このソースリソースはトークンを出力することができないとする。一方、ステップS43の判断において、ソースリソースのSA2(分岐)の条件が満たされたと判断した場合(YES)、トークン制御部16は、ステップS45として、トークンを出力可とする。なお、SA2の条件はそのソースリソースによって異なるが、前記SA2-1をとるソースリソースの場合には、出力先のリソースのすべてについて、それが入力可能であるかどうかを判断することになる。次に、図17には、図15のステップS32における入力条件判断動作の詳細を示す。

【0100】この図17において、トークン制御部16は、ステップS51としてデスティネーションリソース中にトークンが存在していて、且つ、デスティネーションリソースの更に次にトークンが移動するであろうリソースからデスティネーションリソースへの入力可信号が入力不可であるかどうかの条件判断を行う。

【0101】このステップS51の判断において、上記条件が満たされる場合(YES)、トークン制御部16は、ステップS55としてトークンは入力不可とする。一方、ステップS51の判断において、上記条件が満たされない場合(NO)、トークン制御部16は、統いてステップS52として、デスティネーションリソースの前記SA1(受付)の条件が満たされるかどうかを判断する。

【0102】このステップS52の判断において、上記SA1の条件が満たされないと判断した場合(NO)、トークン制御部16は、ステップS55としてトークンは入力不可とする。また、ステップS52の判断において、上記SA1の条件が満たされると判断した場合、トークン制御部16は、更にステップS53として、デスティネーションリソースの入力元のリソースはソースリソース以外にも存在する、つまり、入力元のリソースは複数であるかどうかを判断する。

【0103】このステップS53の判断において、入力元のリソースは複数でないと判断した場合(NO)、トークン制御部16はステップS56としてトークンは入力可とする。一方、ステップS53の判断において、入力元のリソースは複数であると判断した場合(YES)、トークン制御部16は、更にステップS54として、デスティネーションリソースの前記SA3(集約)

の条件が満たされるかどうかを判断する。なお、SA3の条件はそのデスティネーションリソースによって異なるが、SA3-1をとる場合は、入力元のリソースのすべてについて、それぞれがトークンを出力可能であるかどうかを判断することになる。

【0104】このステップS54の判断において、前記SA3の条件が満たされると判断した場合(YES)、トークン制御部16は、ステップS56としてトークンは入力可とする。一方、このステップS54の判断において、前記SA3の条件が満たされないと判断した場合(NO)、トークン制御部16は、ステップS55として、トークンは入力不可とする。

【0105】次に、前記図11で示したように、最小リソース間のトークンの移動とは別に、外部からの入力端になるリソースへのトークンの入力と、外部への出力端となるリソースからのトークンの出力動作があり、この動作について以下に説明する。

【0106】図18には、図11のステップS23である入力端リソースのトークン入力動作を示す。

【0107】ここで、トークンが通る入力端と出力端のリソースをそれぞれ1づつ持つリソースの一連の結合を、リソースのバスと定義する。

【0108】トークン制御部16は、先ずステップS61及びS62として、各モードに対するバスの先頭リソースについて、リソースのUA1とSA1の条件が満たされるかどうかを判断する。なお、UA1の条件とは、前述の図17におけるステップS51の条件と同じである。このステップS61及びS62の判断において、UA1とSA1の条件が満たされないと判断した場合(NO)、トークン制御部16は、ステップS63として外部入出力管理部4に入力不可通知を出して処理を終了する。一方、ステップS61及びS62の判断において、UA1とSA1の条件が満たされると判断した場合(YES)、トークン制御部16は、ステップS63として、モードバッファ2からモード情報を取り出し、さらに性能評価モデル部3の現在のモードを今取り出したモードに変更する。

【0109】その後、トークン制御部16は、ステップS65として、外部入出力管理部4からのトークンを、入力端リソースに移動する。

【0110】次に、図19には、図11のステップS25である出力端リソースのトークン出力動作を示す。

【0111】ここで、リソースのバスはモードによって異なるため、モード毎のリソースバスの終端リソースは複数存在し得る。しかし、それらの終端リソースの次に全てのモードにおいて存在する仮想的な出力端リソースを仮定する。

【0112】この場合の仮想出力端リソースへのトークンの遷移条件は以下のようになる。

【0113】各モード毎の終端リソースが、互いに異な

るリソースR1, R2, …, Rnであり、これらのいずれか2つ以上に同時にトークンが存在して、それらのトークンが外に出ることが可能であるのならば、最も発生時期の古いトークンだけが仮想出力端リソースRに遷移する。このとき、リソースRが受付可能であるかどうかは、外部入出力管理部4からの出力可信号に基づいて決定される。

【0114】この条件のもとで、トークン制御部16は、先ずステップS71及びS72として、各モード毎のパスを統合する仮想出力端リソースについて、リソースのトークン出力条件が満たされるかどうかを判断する。

【0115】当該ステップS71及びS72の判断において、リソースのトークン出力条件が満たされないと判断した場合(NO)、トークン制御部16は処理を終了する。一方、ステップS71及びS72の判断において、リソースのトークン出力条件が満たされると判断した場合(YES)、トークン制御部16は、ステップS73として、外部入出力管理部4からの出力可信号があるかどうかを判断する。

【0116】このステップS73の判断において、外部入出力管理部4からの出力可信号がないと判断した場合(NO)トークン制御部16は処理を終了する。一方、ステップS73の判断において、外部入出力管理部4からの出力可信号があると判断した場合(YES)、トークン制御部16は、ステップS74として、外部入出力管理部4にトークンを出力する。

【0117】以上のように、本発明実施の形態によれば、機能を表現しているアルゴリズム部分と性能に影響を及ぼすアーキテクチャ部分とが切り離され、モードというインターフェイスでその2つの関係を記述した性能評価モデル作成方法及びそのモデルの性能評価がシミュレーションできる性能評価シミュレーション装置を用いることによって、性能評価モデルの作成時に機能評価モデルで作成したアルゴリズム部の再利用が可能となり、性能評価のための設計工数を従来よりも短縮することができる。

【0118】また、本発明実施の形態によれば、同様にして機能評価モデルと独立に性能評価モデルの作成が可能となるので、機能評価モデルが完成しないうちに性能評価モデルの作成が開始できるため、性能評価のための設計工数を従来よりも短縮することができる。

【0119】更に、本発明実施の形態によれば、同様に、機能に依存しない性能評価モデルの作成が可能であることに加え、本発明における性能評価モデルのアーキテクチャ記述方法及びそのモデルの性能評価シミュレーションができる性能評価シミュレーション装置を用いることによって、階層的なアーキテクチャの記述が可能となるので、一般的なハードウェアアーキテクチャ構造を部品化して一旦作成したモデルを再利用することができ、その結果、性能評価のための設計工数を従来よりも短縮することができる。

き、その結果、性能評価のための設計工数を従来よりも短縮することができる。

【0120】また、本発明実施の形態においては、リソーススケジューリングという考え方を用いることによって、性能評価モデルのアーキテクチャ記述方法が容易となり、性能評価のための設計工数を従来よりも短縮することができる。

【0121】更に、本発明実施の形態においては、リソーススケジューリングという考え方に基づいたアーキテクチャ構造の抽象化を用いることにより、そのモデルの性能評価シミュレーションができる性能評価シミュレーション装置の実行を抽象化されたレベルで行うことができるため、シミュレーション実行時間を従来よりも短縮することができる。

#### 【0122】

【発明の効果】以上の説明で明らかなように、本発明の性能評価方法及び装置においては、ハードウェア構造の性能を評価するための性能評価モデルに関する記述を、機能を表現しているアルゴリズム部分と性能に影響を及ぼすアーキテクチャ部分とに分離して記述することにより、性能評価のための設計工数を短くでき、また、シミュレーションの時間をより短縮することを可能としている。

【0123】すなわち、本発明によれば、性能評価モデルの作成時に機能評価モデルで作成したアルゴリズム部の再利用が可能となり、性能評価のための設計工数を従来よりも短縮することができる。また、本発明によれば、機能評価モデルと独立に性能評価モデルの作成が可能となるので、機能評価モデルが完成しないうちに性能評価モデルの作成が開始できるため、性能評価のための設計工数を従来よりも短縮することができる。更に、本発明によれば、機能に依存しない性能評価モデルの作成が可能であることに加え、階層的なアーキテクチャの記述が可能となるので、一般的なハードウェアアーキテクチャ構造を部品化して一旦作成したモデルを再利用することができ、その結果、性能評価のための設計工数を従来よりも短縮することができる。また、本発明においては、リソーススケジューリングという考え方を用いることによって、性能評価モデルのアーキテクチャ記述方法が容易となり、性能評価のための設計工数を従来よりも短縮することができる。更に、本発明においては、リソーススケジューリングという考え方に基づいたアーキテクチャ構造の抽象化を用いることにより、そのモデルの性能評価シミュレーションができる性能評価シミュレーション装置の実行を抽象化されたレベルで行うことができるため、シミュレーション実行時間を従来よりも短縮することができる。

#### 【図面の簡単な説明】

【図1】一般的な性能評価モデルの構造の説明に用いる図である。

【図2】本発明の性能評価モデルの構造の説明に用いる図である。

【図3】本発明におけるリソースの抽象化モデルの概要説明に用いる図である。

【図4】リソースの階層構造の一例を示す図である。

【図5】モードとリソースの結合との関係の説明に用いる図である。

【図6】リソース間トーカンの分散と集約の説明に用いる図である。

【図7】本発明に係る性能評価モデルを作成・検証する一実施の形態の性能評価シミュレーション装置の概略構成例を示すブロック図である。

【図8】モード計算部の動作を示すフローチャートである。

【図9】外部入出力管理部の1クロック毎の動作（その1）を示すフローチャートである。

【図10】外部入出力管理部の1クロック毎の動作（その2）を示すフローチャートである。

【図11】性能評価モデル部の1クロック毎の動作を示すフローチャートである。

【図12】性能評価モデル部の構成例を示すブロック図である。

【図13】ユーザの記述する構造定義部の記述例を示す図である。

【図14】最小単位のリソースへの展開の概念図である。

【図15】リソース間のトーカン移動の基本動作を示すフローチャートである。

【図16】図15のステップS32における出力条件判断動作（ソースリソースのトーカン出力条件判断動作）の詳細を示すフローチャートである。

【図17】図15のステップS32における入力条件判断動作（リソースのトーカン入力条件判断動作）の詳細を示すフローチャートである。

【図18】図11のステップS23である入力端リソースのトーカン入力動作のフローチャートである。

【図19】図11のステップS25である出力端リソースのトーカン出力動作を示すフローチャートである。

【図20】LSI設計者がLSIを設計する場合の従来の設計動作のフローチャートである。

#### 【符号の説明】

- 1 モード計算部、 2 モードバッファ、 3 性能評価モデル、 4 外部入出力管理部、 5 クロック生成器、 6 機能評価モデル、 11 構造定義部、 12 リソース、 13 最小リソース保持部、 14 UA保持部、 15 SA保持部、 16 トーカン制御部

【図1】



【図4】



【図2】



【図3】



リソースの抽象化モデル



【図5】

【図6】



リソース同トーケンの分散と集約

【図7】

【図8】



性能評価シミュレーション装置構成

【図10】



外部入出力管理部の1クロックごとの動作(その2)



【図9】



外部入出力管理部の1クロックごとの動作(その1)

【図11】



性能評価モデル部の1クロックごとの動作

【図12】



【図15】



リソース間のトークン移動の基本動作

【図13】

```

//リソース作成
New SimplePipeline,A;
//SimplePipeline型のリソース名'A'として実体化する

New SimplePipeline,B;
New CustomPipeline,C;
New Register,bR1;
New Register,bR2;
New Register,cR1;

//モード毎のデータバス登録
RegPath B,1,bR1+bR2;
//リソース'B'では、モード'1'のときに
//トークンはあらかじめ宣言されたリソース
//'bR1'・'bR2'の順に流れ
RegPath B,2,bR1+bR1+bR2;
RegPath B,3,bR1+bR1+bR2+bR2;

RegPath C,1,cR1+cR1;
RegPath C,2,cR1;
RegPath C,3,cR1+cR1+cR1;

RegPath A,1,B+C;
RegPath A,2,B+C;
RegPath A,3,B+C;

//最上位リソース登録
RegTop A;
//この性能評価モデルのうち、外部入出力管理部と直接やり取りをするのはリソース'A'である

```

構造定義部の記述の例

【図14】



最小単位のリソースへの展開

【図18】



入力端リソースのトークン入力動作

【図16】



ソースリソースのトークン出力条件判断動作

【図17】



リソースのトークン入力条件判断動作

【図19】



出力端リソースのトークン出力動作

【図20】



従来のLSI設計フロー